本文主要说 Android的组件化的一个规范

Android 组件化规范

修订记录

Date Author Version Description
2017-11-13 wuzongbo 0.0.1 create
2018-03-19 YasinYao 0.0.2 update

目录

组件设计

设计要求

  • 组件必须支持以application方式运行
  • 每个组件最好能写写支持单元测试
  • 一定要考虑多端通用(APP1、APP2、APP3、……)

命名规则

  • 所有module包名必须为com.xxx.widge.mg{组件名}格式
  • 所有的资源必须以“{组件名}_{资源名}”命名,防止资源ID冲突,例如mgbutton_activity_home

组件版本

  • 每个组件统一使用gradle.properties统一管理版本
  • 初始版本为:0.0.1,不要以1.0.0开始
  • 测试版本格式:0.0.1-SNAPSHOT(SNAPSHOT 为快照版本)
  • 正式版本格式:0.0.1

组件依赖

  • 依赖第三方组件,如果不必暴露第三方库,必须使用implementation依赖
  • 禁止组件之间的依赖(很重要!!!),如果有这种需求那你该考虑设计成interface啦

build.gradle 实例

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
apply plugin: 'com.android.library'

android {
compileSdkVersion ANDROID_BUILD_SDK_VERSION as int

defaultConfig {
minSdkVersion ANDROID_BUILD_MIN_SDK_VERSION as int
targetSdkVersion ANDROID_BUILD_TARGET_SDK_VERSION as int
//单个组件版本号,递增
versionCode 1
//组件版本名称,不可修改
versionName VERSION
testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"

}

buildTypes {
release {
minifyEnabled false
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
}
//防止资源ID冲突
resourcePrefix project.name
}

}

dependencies {
implementation fileTree(dir: 'libs', include: ['*.jar'])
implementation deps.supportAppcompatV7
testImplementation deps.junit
}

//maven发布脚本
apply from: '../maven.gradle'

组件发布

  • 配置Maven
  • 单个组件发布命令:./gradlew :{组件名}:uploadArchives
  • 全部组件发布命令:./gradlew uploadArchives

组件使用

组件依赖

  1. 在工程级的build.gradle中增加如下代码

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    allprojects {
    repositories {
    maven { url 'http://192.168.60.96:8082/nexus/content/repositories/android-snapshots/' }
    maven { url 'http://192.168.60.96:8082/nexus/content/repositories/android/' }
    ...
    }

    configurations.all {
    //每隔10分钟检查动态版本的依赖是否更新
    resolutionStrategy.cacheDynamicVersionsFor 10, 'minutes'
    //每隔24小时检查远程依赖是否存在更新
    resolutionStrategy.cacheChangingModulesFor 24, 'hours'
    }
    }
  2. 依赖开发阶段的组件,版本号必须为快照版本(SNAPSHOT),这样有利于快速发布

    1
    implementation "com.xxx.widget:mgbanner:0.0.1-SNAPSHOT"
  3. 正式版依赖

    1
    implementation "com.xxx.widget:mgbanner:0.0.1"

常见问题

  • 如何删除Gradle缓存

    删除”/Users/wuzongbo/.gradle/caches/modules-2/files-2.1/{package}”目录,再同步Gradle文件(Sync Project with Gradle Files)

  • 如何刷新Gradle版本

    在Android studio中Terminal中输入命令:./gradlew –refresh-dependencies

页面跳转

  • 组件之间使用路由地址跳转

    1
    MogoRouter.getInstance().build("mogopartner:///home").open(context);
  • 组件内部跳转Builder跳转

    1
    RoomDetailsActivity_Router.intent(getContext()).roomId(123).start();

组件升级

因为此工程为所有android项目所引用,所以最好能兼容老的版本调用方式就兼容方法与样式

修改方法

比如在有一个方法A(int arg1,int arg2),我们要增加一个参数arg3,我们是不能再原来的方法是直接增加
必须要新增一个方法A(int arg1,int arg2,int arg3),然后再用这个老的方法去调用新的方法,并且给一个默认值

修改前

1
2
int  a(int arg1,int arg2){
return arg1+arg2;

修改后

1
2
3
4
5
6
7
8
}
int a(int arg1,int arg2){
return a(arg1,arg2,0);
}

int a(int arg1,int arg2,int arg3){
return arg1+arg2+arg3;
}

修改样式

比如在有一个组件原来只是伙伴用的,颜色为蓝色, 现在要改为绿色,假设我们把这个颜色做活
那么我们做兼容的时候就需要指定一个默认颜色为蓝色,这样就做到兼容伙伴